home
***
CD-ROM
|
disk
|
FTP
|
other
***
search
/
Monster Media 1994 #2
/
Monster Media No. 2 (Monster Media)(1994).ISO
/
unix
/
xf86read.zip
/
README.LIN
< prev
next >
Wrap
Text File
|
1994-07-26
|
8KB
|
168 lines
Information for Linux Users
---------------------------
Contents
----------
1) Linux versions on which XFree86 has been tested
2) Running XFree86
3) Backwards Compatibility
4) Compiling XFree86
5) Compiling a PEX server
6) Omissions
1 - Linux versions on which XFree86 has been tested
---------------------------------------------------
XFree86 has been tested with Linux version 0.99pl15. It should work
with any later version without change. The binaries and libraries are based
on the 4.5.21 DLL C libraries. The DLL X libraries are produced with the 2.10
dll-tools by Eric Youngdale.
2 - Running XFree86
-------------------
XFree86 is installed in /usr/X386. It requires about 4mb of virtual
memory to run, although having 8mb of RAM is probably the minimum comfortable
configuration. A 387 coprocessor is helpful for 386 machines, although
greater gains in interactive performance are obtained with an increase in
physical memory. Also, a faster graphics card, bus or RAM, will improve
server performance.
After unpacking the tar files, you need to include /usr/X386/lib
in /etc/ld.so.conf (where it should already be by default) or in your
LD_LIBRARY_PATH environment variable. Also, the configuration file
/usr/X386/lib/X11/Xconfig *MUST* be properly filled out based on the host
setup using Xconfig.sample as a starting point and README.Config as
guideline. You may damage your hardware if you use a wrong Xconfig file,
so READ THE DOCS, especially the man pages and the other README files in
/usr/X386/lib/X11/etc.
XFree86 has the ability to perform VT switching to and from the X
server. When first started, XFree86 will automatically locate the first
available VT (one that hasn't been opened by any process), and run on that
VT. If there isn't one available, XFree86 will terminate with an error
message. The server can be run on a specific VT by using the "vt<nn>"
option, where <nn> is the number of an available VT (starting from 1). If
you don't have a free VT XFree86 cannot run. You can increase the number
of available VTs by increasing the value of NR_CONSOLES in
include/linux/tty.h and recompiling the kernel.
Once running inside X, switching to another VT is accomplished by
pressing Ctrl-Alt-<Fnn> where nn is the number of the VT to switch to. To
return to the server, press the proper key-combination that moves you back
to the VT that XFree86 is using: by default, this is Alt-<Fmm>, where mm
is the number of the VT the server is running on (this number is printed
when the server is started). Note that this is NOT the VT from which the
server was started.
NOTE: you can redefine the text-mode keybindings with the 'loadkeys'
command found in the kbd-0.81.tar.gz archive (or a later version thereof).
With this, you can (for example) make Ctrl-Alt-<Fmm> work from text mode
the same way it works under the XFree86 server.
The XFree86 server now queries the kernel to obtain the key
binding in effect at startup. These bindings are either the default map in
place when the kernel was compiled, or reloaded using the 'loadkeys'
utility. Not all keys are bound; special kernel-specific, multiple keysym,
dead keys are not handled by the server. All others are translated to
their X equivalents. Note that the XFree86 server only allows for four
modifier maps: unshifted, shifted, modeswitch unshifted and modeswitch
shifted. Depending on what the modeswitch key is (it is settable in your
Xconfig and defaults to Alt), XFree86 will read those tables into its
keymaps. This means if you use certain keys, like left-Control, for Linux
modeswitch, that will not be mappable to X. Read the manpage XFree86kbd
for more information about X keyboard handling.
When the server is exited, it will return to the original VT it
was started from, unless it dies unexpectedly, when the switch must be
done manually. There still seem to be weird combinations of graphic cards
and motherboards that have problems to restore the textfont when returning
from XFree86 to the text mode. In these cases using the runx script from
the svgalib distribution might help.
There are some quirks that may need some fixing depending on your
configuration. In the past, Linux xload used the BSD method of obtaining
the load average from the running kernel. In the XFree86-1.3 release, that
has been replaced by reading the information from /proc/loadavg instead,
which should be forward-compatible with future kernel releases. Xman has
also been changed to support the GNU groff family instead of the BSD nroff
family. A quick edit and recompile restores BSD conventions. The server
has been modified to provide better console redirection support for
clients, which includes changing the ownership of /dev/console and
/dev/tty0 as well as the VT used to run on. Unfortunately, the kernel
requires that a process be setuid root to perform console redirection, so
xterm and xconsole must be setuid root. As xconsole is not designed with
running setuid root in mind, this opens a big security problem.
3 - Backwards Compatibility
---------------------------
Old binaries (linked to XFree86-1.2, XFree86-1.3 or XFree86-2.0
libraries) will continue to work, but may need an explicit symlink from
/lib/libX{11,t,aw}.so.3 to /usr/X386/lib/libX{11,t,aw}.so.3. Linking with
ld.so against the XView3L5 distribution will give problems with pre-1.3
versions of ld.so, since the XView libraries contain the absolute path to
the shared images, which is discouraged with ld.so. A temporary fix is
including / in /etc/ld.so.config, better recompile XView with relative
library names or get a newer ld.so.
4 - Compiling XFree86
---------------------
There are no special instructions required for compiling XFree86.
This version was compiled with gcc-2.5.8, the 4.4.21 DLL libraries and the
1.4 shared, dynamic linker ld.so. The tools-2.10 DLL package was used to
generate the shared libraries. The server has been compiled with -m486,
which optimizes it for the 486 processor, but the binary will run on the
386 processor (there is a slight increase in binary size over using -m386,
but no loss of performance).
The distribution is very large, but it is possible to compile
XFree86 on a single 64mb partition, if the source tree is carefully
trimmed (no manpages, PEX or large clients). Simply run "make Makefiles"
to create the Makefiles, then stop the make and run each piece
individually. It is not necessary to run "make depend" as well, which
saves some space. Having 100mb available makes compiling XFree86 a lot
easier. You will need about 10mb of virtual memory to compile the entire
server.
There is support now for creating X DLL libraries. By default,
certain libraries are compiled into both static and shared form, but this
can be changed by editing mit/config/lnuxLib.rules. The new shared library
symlinks no longer need to be moved to /lib, as starting with XFree86-2.0
the shared, dynamic linker ld.so is used.
If patches are applied which change the libraries, modified
jump_xxx files will be needed. Those can be generated according to
instructions given in the dll tools package, and will be made available as
XFree86 patches. The file mit/config/lnuxLib.rules contains detailed
instructions about defining the JUMP_xxx variables for compiling an
external X shared lib using the X shared libs.
Thanks to Dirk Hohndel (hohndel@informatik.uni-wuerzburg.de) for
working out all the details and doing all the work in creating the first
set of XFree86 DLL libs, on which the current method (developed by Orest
Zborowski (orestz@microsoft.com)) is based.
5 - Compiling a PEX server
--------------------------
PEX is now a part of the XFree86 source distribution and including
it in the server is trivial. First, edit mit/config/site.def and change
BuildPex from NO to YES, then perform a make World. The server, libraries
and demos will all get built with PEX support. After installation, the
new server can be verified by using xdpyinfo, which should show X3D-PEX
as an available extension. Alternatively you can use the LinkKit to
produce a server including PEX. See the relevant docs in
/usr/X386/lib/Server/README.
6 - Omissions
-------------
With each release there are fewer omissions from the basic X11R5
offering. Starting with XFree86-2.0 the MITSHM (shared memory) extensions
are included. Now only the XINPUT extension is missing.
$XFree86: mit/server/ddx/x386/README.Linux,v 2.7 1994/03/08 08:31:17 dawes Exp $